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DETERMINING THE PARTICIPANTS IN A DISTRIBUTED OPERATION 

FIELD OF THE INVENTION 

The present invention relates to distributed computer systems, and in particular, to 
5 determining the participants in a distributed operation. 

BACKGROUND OF THE INVENTION 

One of the long standing challenges in computing is the detection of deadlocks. A 
deadlock occurs if a set of entities exists such that each entity in the set is waiting for the 

10 release of at least one resource owned by another entity in the set. Entities capable of 
owning a resource are referred to herein as possessory entities. In the context of a 
database system, for example, possessory entities include processes and transactions. A 
transaction is an atomic unit of work. 

For example, a transaction Tl may seek exclusive ownership of resources Rl and 

15 R2. If Rl is available and R2 is currently exclusively owned by anther transaction T2, 
transaction Tl may acquire exclusive ownership of Rl but must wait for R2 to become 
available. A deadlock will occur if transaction T2 seeks ownership of Rl, and T2 is 
suspended to wait for Rl without releasing R2. Because both Tl and T2 are waiting for 
each other, they are deadlocked. 

20 Computer systems employ a variety of deadlock handling mechanisms (deadlock 

handlers) that detect deadlocks. Many of deadlock handlers employ the "cycle" technique 
to detect deadlocks. In the cycle technique, after a process waits a threshold period of 
time for a resource, a wait-for graph is generated and examined for any cycles. If any 
cycles are identified, then the deadlock detection mechanism has identified a potential 

25 deadlock. 

A wait-for graph is a graph that includes vertices that represent resources 
("resource vertices") and vertices that represent possessory entities ("entity vertices "). 


50277-236 (OID 1998-02-01) 


2 


An arc from an entity vertex to a resource vertex represents that the respective possessory 
entity represented by the entity vertex is waiting for ownership of the resource. An arc 
from a resource vertex to a entity vertex represents that the resource represented by the 
resource vertex is owned by the possessory entity. A cycle is detected when a chain of 

5 arcs leads both to and from the same vertex. 

Fig. 1 shows an exemplary wait-for graph 100, which includes entity vertices 1 1 1 
and 1 12 and resource vertices 121 and 122. Wait-for graph 100 was generated when a 
deadlock handler detected that the process represented by entity vertex 1 1 1 had waited a 
threshold period of time for the resource represented by resource vertex 121. Arc 131 

10 represents that the process represented by entity vertex 1 1 1 is requesting ownership of the 
resource represented by resource vertex 121. Arc 132 represents that the resource 
represented by resource vertex 121 is owned by the process represented by entity vertex 
1 12. Arc 133 represents that the process represented by entity vertex 1 12 has requested 
the resource represented by resource vertex 122. Arc 134 represents that the resource 

1 5 represented by resource vertex 122 is owned by the resource represented by entity vertex 
111. 

Arcs 131, 132, 133, and 134 form a loop that both extends from and leads to 
entity vertex 1 1 1, and thus represents a cycle. The processes represented by the entity 
vertices of wait-for graph 100 are therefore potentially deadlocked. 

20 In a distributed computer system, the resources and entities involved in deadlocks 

may be distributed among many nodes. Thus, in the example given above, transaction Tl 
may reside on one node, while transaction T2 resides on another node. Detecting 
deadlocks on distributed computer systems may involve generating "distributed wait-for 
graphs". Distributed wait-for graphs are wait-for graphs that include entity vertices for 

25 entities that may be from many nodes. 

Typically, the set of nodes that are executing the entities that may be involved in a 
deadlock cooperate with each other to generate the distributed wait-for-graph, each node 
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producing the portion of the distributed wait-for graph that covers the node's respective 
entities. A process such as the deadlock handler is responsible for splitting the task of 
generating the distributed wait-for graph to each node of the set of nodes. Thus, 
generating distributed wait-for graphs involves identifying which nodes may be executing 

5 entities involved in a possible deadlock. 

To determine which nodes may be involved in a possible deadlock on a 
distributed computer system, a deadlock handler may query all the nodes in the 
distributed computer system for information that indicates whether they may be involved 
in a deadlock. For example, assume that a deadlock handler in a distributed database 

1 0 system has detected that a distributed transaction has been waiting for a resource for a 
threshold period of time. A distributed transaction is a transaction executed by database 
servers, which may reside on multiple nodes. 

When a deadlock handler detects that the distributed transaction has been waiting 
a threshold period of time for a distributed resource, it may identify the multiple database 

1 5 servers involved in the distributed transaction through the broadcast query technique. In 
the broadcast query technique, the deadlock handler broadcasts a query to each database 
server in the distributed database system. The query requests information about whether 
the database server is involved in the distributed transaction. 

Communication between database servers, especially those residing on different 

20 nodes, can involve a relatively large amount of overhead, and may substantially delay 
receipt by the detection handler of the information required to build the wait-for graph. 
Often, the costs in overhead and delays is so great that deadlock handlers are configured 
to forego the cycle technique when attempting to detect deadlocks that may involve 
distributed resources. Instead, other deadlock detection techniques are used. 

25 One common alternative to the cycle technique for detecting deadlocks is the 

time-out technique. Under the time-out technique, a possessory entity is presumed to be 
involved in a deadlock once the possessory entity waits a threshold period of time to 
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obtain ownership of a resource. The time-out technique is less accurate in detecting 
deadlocks, since delays in obtaining ownership of a resource may result from many 
causes other than deadlock. 

Based on the foregoing, it is desirable to provide a more efficient method of 
5 generating information about which nodes may have resources that are involved in a dead 
lock, and in more general, participants that may be involved in a distributed operation, 
such as a distributed transaction. 
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SUMMARY OF THE INVENTION 

A mechanism and system are described for making available information that 
identifies participants of a distributed operation by registering the information with a 
name service. Once the participant information has been registered with the name 
5 service, the name service supplies the information to entities that request it. An example 
of a distributed operation is a distributed transaction executed by two or more database 
servers. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention is illustrated by way of example, and not by way of 
limitation, in the figures of the accompanying drawings and in which like reference 
numerals refer to similar elements and in which: 

Fig. 1 is a block diagram depicting an exemplary wait-for graph; 

Fig. 2 is a block diagram depicting an exemplary distributed database system 
upon which an embodiment of the present invention may be implemented; and 

Fig. 3 is a block diagram depicting a computer system upon which an 
embodiment of the present invention may be implemented. 
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DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

A method and apparatus for providing information about the participants in a 
distributed operation is described. In the following description, for the purposes of 
explanation, numerous specific details are set forth in order to provide a thorough 
5 understanding of the present invention. It will be apparent, however, to one skilled in the 
art that the present invention may be practiced without these specific details. In other 
instances, well-known structures and devices are shown in block diagram form in order to 
avoid unnecessarily obscuring the present invention. 

1 o FUNCTIONAL OVERVIEW 

A mechanism and system are provided for making available information that 
identifies participants of a distributed operation by registering the information with a 
name service. Once the participant information has been registered with the name 
service, the name service supplies the information to entities that request it. A name 
1 5 service shall be described in greater detail hereafter. 

A distributed operation is an operation in which processes on multiple nodes 
participate in the accomplishment of the operation. One example of a distributed 
operation is a distributed transaction executed by two or more database servers. 
However, it should be noted that there are many types of distributed operations. The 
20 present invention is not limited to any particular type of distributed operation. 

As used herein, the term "participant set" refers to a set of entities that are 
participating in a distributed operation. A participant set does not necessarily include all 
the entities participating in a distributed operation. Entities which may be members of a 
participant set include, for example, processes, transactions, database servers, and nodes 
25 on which processes reside. 

Techniques for providing information identifying participant set members are 
illustrated herein in the context of a deadlock detection mechanism in a distributed 
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database system. A process participating in a distributed transaction registers information 
that identifies the members of the participant set of a distributed transaction. The 
deadlock detection mechanism, which requires this information to generate a distributed 
wait-for graph, retrieves the information from the name service. 

5 

EXEMPLARY DISTRIBUTED DATABASE SYSTEM 

Fig. 2 shows a distributed database system 200 used to illustrate techniques for 
providing information identifying participant set members according to an embodiment 
of the present invention. Distributed database system 200 shows database servers 210, 
10 230, 250, and 270, which reside on different nodes on a shared everything system, shared 
disk system, or shared nothing system. A database server is a combination of a set of 
processes and memory allocated to those processes. These processes include processes 
that execute transactions and processes that support those processes executing 
transactions. 

1 5 Fig. 2 also shows the various processes executing a distributed transaction X on 

distributed database system 200. These processes include coordinator process 222, which 
is responsible for coordinating other processes participating in distributed transaction X. 
These other processes include slaves 232 and 234 on database server 230, slave 236 on 
database server 270, and slave 252 on database server 250. 

20 The database servers that have processes participating in a particular distributed 

transaction are referred to as a spanning set. The spanning set of the distributed 
transaction X thus includes database servers 210, 230, 250, and 270. For a particular 
distributed transaction, the spanning set is a participant set. 

EXEMPLARY NAME SERVICE 

25 The spanning set of distributed transaction X is communicated through a name 

service 202. Name service 202 is a computer component (e.g. a set of processes and a 
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name-entry database) dedicated, at least in part, to registering information received from 
clients and providing that information to clients mat request the information. Name 
service 202 allows a name service client to make information available to other name 
service clients. 

5 To register information with name service 202 and make the information 

available to name service clients, a name service client transmits a publication request to 
the name service 202. A publication request is a request to make information available to 
a set of name service clients that request the information. Typically, the publication 
request includes a key and data associated with the key. The data associated with the key 
10 is referred to as published data because once name service 202 receives the published 
data and the associated key, the name service 202 supplies the data to any name service 
client requesting data associated with the key. 

Fig. 2 shows name service 202 according to an embodiment of the present 
invention. Name service 202 includes processes ("name service processes", not shown) 
15 within each of database servers 210, 230, 250, and 270. Often, a name service client 
directs its name service requests to a local name service process. Such a local name 
service processes may be, for example, a name service process within the same database 
server as the name service client, or a name service process that resides on the same node 
as the name service client. Published data is replicated and stored on each of database 
20 servers 210, 230, 250, and 270, as replicated published data 219, 239, 259, and 279. 

REGISTERING PARTICIPANT DATA IN A NAME SERVICE 

In order to provide data indicating the members of the spanning set of a 
distributed transaction to a node requiring that information, data indicating members of 
25 the spanning set are registered with name service 202. To register the data, coordinator 
process 222 transmits a publication request to name service 202, such as publication 
request 224. Publication request 224 specifies a published spanning set and a distributed 
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operation key. A published spanning set is published data that indicates a spanning set for 
a distributed transaction. A distributed operation key is a key to associate with published 
data identifying participants of a distributed operation, such as a spanning set. The 
distributed operation key used in this example is the distributed transaction id X. A 
5 distributed transaction id is data that identifies a distributed transaction, such as 
distributed transaction X. 

While the present invention has been illustrated using a distributed transaction id 
as a distributed operation key, other types of distributed operation keys are possible. 
Therefore, the present invention is not limited to distributed operation keys that are 
1 0 distributed transaction ids. 

The spanning set may change as a distributed transaction progresses. So that the 
published spanning set accurately reflects the actual members of the spanning set, the 
coordinator process may update the published spanning set at various stages throughout 
life of the respective distributed transaction. For example, when a distributed transaction 
1 5 is initiated, the coordinator process causes the spawning of one or more slave processes, 
such as slaves 232, 234, and 236. Because all of the processes participating in distributed 
transaction X are on database servers 210, 230, and 270, coordinator process 222 
transmits to name service 202 a publication request that specifies (1) that the published 
spanning set is database servers 210, 230, and 270, and (2) that distributed transaction 
20 identifier X is the distributed operation key to associate with the published spanning set. 
Later, coordinator process 222 spawns slave 252, expanding the spanning set. 
Coordinator process 222 also transmits a publication request in the manner previously 
described, except that the publication request specifies as published data the members of 
the expanded spanning set which now includes database servers 210, 230, 270 and 250. 
25 While the present invention has been illustrated using a coordinator process that 

transmits publication requests to register participant set information, other types of 
entities may register participant set information. These other types of entities include 
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slaves participating in a distributed transaction, and entities not participating in the 
distributed operation. For example, in the previous example in which coordinator process 
222 causes the spawning of slave 252, slave 252 may register itself as a participant in the 
distributed transaction. Specifically, slave 252 transmits a request to modify the 
5 published spanning set associated with distributed transaction id X to include database 
server 250 in the spanning set. 

RETRIEVING PARTICIPANT DATA 

Once the published spanning set of a distributed transaction has been registered 

10 with name service 202, a node that requires information about the published spanning set 
may use the distributed transaction id as a key to retrieve the published spanning set from 
the name service. The phrase "a node that requires information" refers to a node having 
any entity, such as a process or transaction, that requires the information. For example, a 
node that requires information about the published spanning set for distributed 

1 5 transaction X could be a node with a slave that requires the information, or a node with 
processes not participating in the distributed transaction that require the information. 

Referring to Fig. 2, deadlock handler 274 is an example of a process that requires 
knowledge of the spanning set of a distributed transaction X, and that retrieves the 
published spanning set from name service 202. A deadlock handler may be a distributed 

20 lock manager that manages access to resources, such as resource 275. To manage access 
to a particular resource, a distributed lock manager uses locks, such as lock 276. A lock is 
a data structure that contains information about ownership of a particular resource by a 
particular entity. The information includes data about what entity has requested the 
resource, and whether the resource is waiting to own the resource or in fact owns the 

25 resource. A lock for a participant in a distributed operation may include data specifying 
the corresponding distributed operation key, for example, a distributed transaction id. 
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Lock 276 represents the state of ownership of resource 275 by slave 236. Lock 
276 indicates that slave 236 has been waiting for resource 275. Lock 276 includes 
distributed transaction id field 277, which contains data specifying the distributed 
transaction id of the distributed transaction whose ownership lock 276 represents. In 
5 particular, distributed transaction id field 277 contains data specifying distributed 
transaction X. 

Deadlock handler 274 eventually determines that lock 276 indicates that slave 236 
has been waiting for resource 275 a threshold period of time. After detecting that slave 
236 has been waiting a threshold period of time, deadlock handler 274 begins the process 

10 of detecting whether slave 236 may be deadlocked using the cycle technique. Before 
generating the distributed wait-for graph needed for the cycle technique, deadlock 
handler 274 determines the spanning set. 

To determine the spanning set, deadlock handler 274 queries name service 202 for 
the published spanning set using distributed transaction id X. Specifically, deadlock 

1 5 handler mechanism 274 retrieves, from distributed transaction id field 277 of lock 276, 
data that specifies the distributed transaction id X. Deadlock handler 274 then transmits 
to name service 202 a request for published data associated with distributed transaction id 
X. In response, name service 202 returns the published spanning set, which specifies 
database servers 210, 230, 250, and 270 as participants in distributed transaction X. 

20 Once deadlock handler 274 receives the published spanning set for distributed 

transaction X, it begins construction of the distributed wait-for graph. 

As compared to the broadcast query technique previously discussed, registering 
with a name service information indicating the members of a spanning set allows a node 
needing to know this information to obtain it more efficiently. Specifically, information 

25 about the participant set is provided to deadlock handler 274 by performing a set of 
operations local to the node on which deadlock handler 274 resides. Deadlock handler 
274 transmits a request for the published spanning set to a name service process that 
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resides on the same node. The name service process retrieves the information from 
replicated published data that also resides on the same node. 

Even when a name service process or the replicated published data is not located 
locally to a process, a name service may supply the information about the members of a 
spanning set more efficiently than it may be supplied under the broadcast technique. 
Specifically, transmitting a request and receiving a response from a single name service 
process located on a remote node may be performed more efficiently than transmitting 
multiple requests and receiving multiple responses from multiple processes located on 
remote nodes in a distributed database system. It should be understood that the present 
invention is not limited to a system where name service processes are located on the same 
node as the processes they service. 

Providing information about the members of a participant set more efficiently 
improves efficiency of distributed operations that require this information. In addition, 
distributed operations, such as the generation of distributed wait-for graphs in a 
distributed database system, that were infeasible to perform because of inefficiencies 
attendant to determining the participant set, become feasible to perform. 

The present invention has been illustrated using a deadlock handling mechanism 
that needed to know the members of a participant set of a distributed transaction. 
However, other embodiments of the present invention may involve other types of entities 
that need to know participants of other types of distributed operations. Therefore, it is 
understood that the present invention is not limited to providing information about the 
participant set of any particular type of distributed operation to any particular type of 
entity needing to know such information. 
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HARDWARE OVERVIEW 
Figure 3 is a block diagram that illustrates a computer system 300 upon which an 
embodiment of the present invention may be implemented. Computer system 300 
includes a bus 302 or other communication mechanism for communicating information, 

5 and a processor 304 coupled with bus 302 for processing information. Computer system 
300 also includes a main memory 306, such as a random access memory (RAM) or other 
dynamic storage device, coupled to bus 302 for storing information and instructions to be 
executed by processor 304. Main memory 306 also may be used for storing temporary 
variables or other intermediate information during execution of instructions to be 

10 executed by processor 304. Computer system 300 further includes a read only memory 
(ROM) 308 or other static storage device coupled to bus 302 for storing static 
information and instructions for processor 304. A storage device 310, such as a magnetic 
disk or optical disk, is provided and coupled to bus 302 for storing information and 
instructions. 

1 5 Computer system 300 may be coupled via bus 302 to a display 312, such as a 

cathode ray tube (CRT), for displaying information to a computer user. An input device 
314, including alphanumeric and other keys, is coupled to bus 302 for communicating 
information and command selections to processor 304. Another type of user input device 
is cursor control 316, such as a mouse, a trackball, or cursor direction keys for 

20 communicating direction information and command selections to processor 304 and for 
controlling cursor movement on display 312. This input device typically has two degrees 
of freedom in two axes, a first axis (e.g., x) and a second axis (e.g., y), that allows the 
device to specify positions in a plane. 

The invention is related to the use of computer system 300 for providing 

25 information about the participants in a distributed operation. According to one 
embodiment of the invention, providing information about the participants in a 
distributed operation is provided by computer system 300 in response to processor 304 
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executing one or more sequences of one or more instructions contained in main memory 
306. Such instructions may be read into main memory 306 from another computer- 
readable medium, such as storage device 310. Execution of the sequences of instructions 
contained in main memory 306 causes processor 304 to perform the process steps 

5 described herein. In alternative embodiments, hard-wired circuitry may be used in place 
of or in combination with software instructions to implement the invention. Thus, 
embodiments of the invention are not limited to any specific combination of hardware 
circuitry and software. 

The term "computer-readable medium" as used herein refers to any medium that 

10 participates in providing instructions to processor 304 for execution. Such a medium 
may take many forms, including but not limited to, non-volatile media, volatile media, 
and transmission media. Non-volatile media includes, for example, optical or magnetic 
disks, such as storage device 310. Volatile media includes dynamic memory, such as 
main memory 306. Transmission media includes coaxial cables, copper wire and fiber 

1 5 optics, including the wires that comprise bus 302. Transmission media can also take the 
form of acoustic or light waves, such as those generated during radio-wave and infra-red 
data communications. 

Common forms of computer-readable media include, for example, a floppy disk, a 
flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any 

20 other optical medium, punchcards, papertape, any other physical medium with patterns of 
holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or 
cartridge, a carrier wave as described hereinafter, or any other medium from which a 
computer can read. 

Various forms of computer readable media may be involved in carrying one or 
25 more sequences of one or more instructions to processor 304 for execution. For example, 
the instructions may initially be carried on a magnetic disk of a remote computer. The 
remote computer can load the instructions into its dynamic memory and send the 
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instructions over a telephone line using a modem. A modem local to computer system 
300 can receive the data on the telephone line and use an infra-red transmitter to convert 
the data to an infra-red signal. An infra-red detector can receive the data carried in the 
infra-red signal and appropriate circuitry can place the data on bus 302. Bus 302 carries 

5 the data to main memory 306, from which processor 304 retrieves and executes the 

instructions. The instructions received by main memory 306 may optionally be stored on 
storage device 310 either before or after execution by processor 304. 

Computer system 300 also includes a communication interface 318 coupled to bus 
302. Communication interface 3 1 8 provides a two-way data communication coupling to 

10 a network link 320 that is connected to a local network 322. For example, 

communication interface 318 may be an integrated services digital network (ISDN) card 
or a modem to provide a data communication connection to a corresponding type of 
telephone line. As another example, communication interface 318 may be a local area 
network (LAN) card to provide a data communication connection to a compatible LAN. 

1 5 Wireless links may also be implemented. In any such implementation, communication 
interface 318 sends and receives electrical, electromagnetic or optical signals that carry 
digital data streams representing various types of information. 

Network link 320 typically provides data communication through one or more 
networks to other data devices. For example, network link 320 may provide a connection 

20 through local network 322 to a host computer 324 or to data equipment operated by an 
Internet Service Provider (ISP) 326. ISP 326 in turn provides data communication 
services through the world wide packet data communication network now commonly 
referred to as the "Internet" 328. Local network 322 and Internet 328 both use electrical, 
electromagnetic or optical signals that carry digital data streams. The signals through the 

25 various networks and the signals on network link 320 and through communication 
interface 318, which carry the digital data to and from computer system 300, are 
exemplary forms of carrier waves transporting the information. 
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Computer system 300 can send messages and receive data, including program 
code, through the network(s), network link 320 and communication interface 318. In the 
Internet example, a server 330 might transmit requested code for an application program 
through Internet 328, ISP 326, local network 322 and communication interface 318. In 
accordance with the invention, one such downloaded application provides for providing 
information about the participants in a distributed operation as described herein. 

The received code may be executed by processor 304 as it is received, and/or 
stored in storage device 3 10, or other non-volatile storage for later execution. In this 
manner, computer system 300 may obtain application code in the form of a carrier wave. 

In the foregoing specification, the invention has been described with reference to 
specific embodiments thereof. It will, however, be evident that various modifications and 
changes may be made thereto without departing from the broader spirit and scope of the 
invention. The specification and drawings are, accordingly, to be regarded in an 
illustrative rather than a restrictive sense. 
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CLAIMS 

What is claimed is: 


1 1 . A method of determining participants of a distributed operation in a distributed 

2 system, the method comprising the steps of: 

3 registering in a name service participant data that identifies a plurality of 

4 participants that are participating in said distributed operation; and 

5 causing a node that requires information about participants in said distributed 

6 operation to retrieve said participant data from said name service. 

1 2. The method of Claim 1 , wherein the step of causing a node to retrieve said 

2 participant data includes causing said node to retrieve said participant data in 

3 response to said node performing deadlock detection. 

1 3 . The method of Claim 1 , wherein: 

2 said distributed operation is a distributed transaction; and 

3 the step of registering includes registering in a name service participant data that 

4 identifies which database servers of a plurality of database servers are 

5 participating in said distributed transaction. 

1 4. The method of Claim 1 ? further including the step of causing updates to said 

2 participant data to identify a new participant in said distributed operation. 

1 5 . The method of Claim 4, wherein: 
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2 said distributed operation is a distributed database transaction being executed by a 

3 set of processes coordinated by a coordinator process; 

4 the method further includes the step of said coordinator process causing a new 

5 process on a database server to participate in said distributed database 

6 transaction; and 

7 the step of causing updates to said participant data includes said coordinator 

8 process causing updates to said participant data in response to said new 

9 process participating in said distributed database transaction. 

1 6. The method of Claim 1 , wherein 

2 said distributed operation is a distributed database transaction; 

3 the step of registering includes registering participant data that identifies which 

4 database servers of a plurality of database servers are participating in said 

5 distributed database transaction; and 

6 the step of causing a node to retrieve said participant data includes causing a node 

7 that requires information about participants in said distributed database 

8 transaction to retrieve said participant data from said name service. 

1 7. The method of Claim 1 , wherein: 

2 said distributed operation is a distributed database transaction; 

3 the method further includes the step of assigning a transaction identifier to said 

4 distributed database transaction; 

5 the step of registering includes registering in said name service data that associates 

6 said participant data with said transaction identifier; and 
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7 the step of causing a node includes causing a node to request from said name 

8 service published data associated with said transaction identifier. 

1 8. The method of Claim 1, wherein the step of causing a node to retrieve said 

2 participant data includes said name service process receiving a request from a first 

3 process to supply said participant data, wherein said name service process and 

4 said first process reside on said node. 

1 9. The method of Claim 8, wherein the step of causing a node to retrieve said 

2 participant data includes said name service process retrieving said participant data 

3 from one or more data structures residing on said node in response to receiving 

4 said request. 

1 10. The method of Claim 1, wherein the step of causing a node to retrieve said 

2 participant data includes a name service process receiving a request from a first 

3 process to supply said participant data, wherein said name service process and 

4 said first process reside on said node. 

1 11. A computer-readable medium carrying one or more sequences of one or more 

2 instructions for determining participants of a distributed operation in a distributed 

3 system, the one or more sequences of one or more instructions including 

4 instructions which, when executed by one or more processors, cause the one or 

5 more processors to perform the steps of: 

6 registering in a name service participant data that identifies a plurality of 

7 participants that are participating in said distributed operation; and 
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8 causing a node that requires information about participants in said distributed 

9 operation to retrieve said participant data from said name service. 

1 1 2. The computer-readable medium of Claim 1 1 , wherein the step of causing a node 

2 to retrieve said participant data includes causing said node to retrieve said 

3 participant data in response to said node performing deadlock detection. 

1 13. The computer-readable medium of Claim 1 1 , wherein: 

2 said distributed operation is a distributed transaction; and 

3 the step of registering includes registering in a name service participant data that 

4 identifies which database servers of a plurality of database servers are 

5 participating in said distributed transaction. 

1 14. The computer-readable medium of Claim 1 1 , further including the step of causing 

2 updates to said participant data to identify a new participant in said distributed 

3 operation. 

1 15. The computer-readable medium of Claim 1 4, wherein: 

2 said distributed operation is a distributed database transaction being executed by a 

3 set of processes coordinated by a coordinator process; 

4 the computer-readable medium further includes sequences of instructions for 

5 performing the step of said coordinator process causing a new process on a 

6 database server to participate in said distributed database transaction; and 
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7 the step of causing updates to said participant data includes said coordinator 

8 process causing updates to said participant data in response to said new 

9 process participating in said distributed database transaction. 

1 16. The computer-readable medium of Claim 1 1 ? wherein 

2 said distributed operation is a distributed database transaction; 

3 the step of registering includes registering participant data that identifies which 

4 database servers of a plurality of database servers are participating in said 

5 distributed database transaction; and 

6 the step of causing a node to retrieve said participant data includes causing a node 

7 that requires information about participants in said distributed database 

8 transaction to retrieve said participant data from said name service. 

1 1 7. The computer-readable medium of Claim 1 1 , wherein: 

2 said distributed operation is a distributed database transaction; 

3 the computer-readable medium further includes sequences of instructions for 

4 performing the step of assigning a transaction identifier to said distributed 

5 database transaction; 

6 the step of registering includes registering in said name service data that associates 

7 said participant data with said transaction identifier; and 

8 the step of causing a node includes causing a node to request from said name 

9 service published data associated with said transaction identifier. 

1 18. The computer-readable medium of Claim 11, wherein the step of causing a node 

2 to retrieve said participant data includes said name service process receiving a 
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3 request from a first process to supply said participant data, wherein said name 

4 service process and said first process reside on said node. 

1 19. The computer-readable medium of Claim 1 8, wherein the step of causing a node 

2 to retrieve said participant data includes said name service process retrieving said 

3 participant data from one or more data structures residing on said node in response 

4 to receiving said request, 

1 20. The computer-readable medium of Claim 1 , wherein the step of causing a node to 

2 retrieve said participant data includes a name service process receiving a request 

3 from a first process to supply said participant data, wherein said name service 

4 process and said first process reside on said node. 
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ABSTRACT OF THE DISCLOSURE 

A mechanism and system are provided for making available information that 
identifies participants of a distributed operation by registering the information with a 
name service. Once the participant information has been registered with the name 
service, the name service supplies the information to entities that request it. An example 
of a distributed operation is a distributed transaction executed by two or more database 
servers. 
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Reg. No. 39.762; Michael E. McCabe, Jr., Reg. No. 37,182; James H. Meadows, Reg. 
No. 33,965; Michael A. Messina, Reg. No. 33,424; Christopher J. Palermo, Reg. No. 
42,056; Joseph H. Paquin, Jr., Reg. No. 31,647; Craig L. Plastrik, Reg. No. 41,254; 
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Robert L. Price, Reg. No. 22,685; Paul A. Roberts, Reg. No. 40,289; Gene Z. Rubinson, 
Reg. No. 33,351 ; Joy Ann G. Serauskas, Reg. No. 27,952; Michele M. Schafer, Reg. No. 
34,717; David J. Serbin, Reg. No. 30,589; Glenn Snyder, Reg. No. 41,428; Arthur J. 
Steiner, Reg. No. 26,106; David L. Stewart, Reg. No. 37,578; Leonid D. Thenor, Reg. No. 
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